본문으로 이동

코사라주 알고리즘

위키백과, 우리 모두의 백과사전.

컴퓨터 과학에서 코사라주 알고리즘 (코사라주-샤리르 알고리즘으로도 알려져 있다.)은 유향그래프에서의 강한 연결 요소를 선형 시간에 찾는 알고리즘이다. 앨프리드 에이호, 존 홉크로프트 및 제프리 울만은 이 알고리즘을 삼바시바 코사라주미샤 샤리르의 것으로 보증한다. 삼바시바 코사라주는 1978년에 이 알고리즘을 제안하였지만 출판하지 않았고, 1981년 미샤 샤리르는 독자적으로 알고리즘을 발견하고 출판하였다. 이 알고리즘은 역방향 그래프(모든 간선들의 방향을 뒤집은 그래프)가 원래 그래프와 정확히 같은 강한 연결 요소를 갖는다는 사실을 이용한다.

알고리즘

[편집]

코사라주 알고리즘은 크게 네 가지의 그래프 연산을 바탕으로 한다.

  • 그래프의 정점들을 열거하는 연산
  • 정점마다 데이터를 저장하는 연산(그래프의 자료 구조 안에 저장하는 방법 뿐만 아니라 정점들을 인덱스로 하는 배열에 저장하는 방법도 있다.)
  • 정점에서 나가는 방향의 이웃(순방향 이웃) 정점들을 열거하는 연산(순방향 탐색)
  • 정점에서 들어오는 방향의 이웃(역방향 이웃) 정점들을 열거하는 연산(역방향 탐색)

마지막 연산에서 원본 그래프를 역방향 그래프로 표현하는 것은 순방향 순회를 할 때 비용 없이 가능하다. 이 알고리즘에 필요한 유일한 자료 구조는 그래프 정점들의 순서가 매겨진 목록 L 이다. 이 목록은 각 정점을 한번씩 포함하게 된다.

만약 그래프의 강한 연결 요소들을 각 구성 요소에 대해 별도의 루트 정점을 지정하고 각 정점에 구성 요소의 루트 정점을 할당함으로써 표현할 경우 코사라주의 알고리즘은 다음과 같이 적용될 수 있다.

  1. 그래프의 각 정점 u 에 대하여, u 를 방문되지 않은 것으로 표시한다. 이때, 목록 L 은 비어 있다.
  2. 그래프의 각 정점 u 에 대하여 정점을 방문하는 함수인 Visit(u)를 수행하고, Visit(u)는 재귀적으로 서브루틴을 작동시킨다.
    만약 가 방문되지 않았다면:
    1. u 를 방문한 것으로 표시한다.
    2. 의 바깥쪽 이웃 v 에 대해 Visit(v)를 수행한다.
    3. 앞에 를 추가한다.
    그렇지 않으면:
          아무것도 하지 않는다
  3. L 에 순서에 따라 각 원소 u에 대하여 강한 연결 요소에 할당시키는 함수인 Assign(u,u) Assign(u,루트)는 재귀적으로 서브루틴을 작동시킨다.
    만약 u 가 할당되지 않은 요소라면:
    1. 루트가 루트인 강한 연결 요소에 u를 포함시킨다.
    2. u 의 안쪽 이웃 v 에 대해 Assign(v,루트)를 수행한다.
    그렇지 않으면:
          아무것도 하지 않는다

각 정점에 강한 연결 요소의 번호를 할당하거나 강한 연결 요소 별로 포함하고 있는 정점의 리스트를 만드는 등의 사소한 변형이 가능하다. 방문하지 않음/방문함 표시의 저장 장소는 정점마다 루트를 최종적으로 할당할 때 공유될 수 있다.

이 알고리즘의 중요한 부분은 그래프 간선의 첫번째(순방향) 순회 때, 정점들이 트리가 탐색되는 순서와 같이 후위 순서의 관계로 검색트리 목록 에 추가된다는 것이다. 이것은 정점 v 가 처음 방문되었는지와 무관하다. 왜냐하면 정점 가 방문되는 경우는 모든 정점들이 나열된 L에서 나타나거나, 방문된 다른 정점 uv의 바깥 이웃이여서 나타나기 때문이다. L 에 가 u 보다 앞에 추가되었다는 것은 어느쪽으로든 간에 u에서 v로의 순방향 경로가 존재한다면 최종 리스트에는 가 보다 앞에 나타나기 때문이다.(만약 v 모두 같은 강한 연결 요소에 포함되지 않는다면, L에서 그들의 상대적 순서는 임의적이다. 간결함을 위해 깊이 우선 탐색을 채용한 알고리즘이 위에 기술되어있지만, 후위 순회의 특성이 보존되는 경우 너비 우선 탐색에 대해서도 작동한다.

시간 복잡도

[편집]

그래프가 인접 리스트의 형태로 주어질 때, 코사라주의 알고리즘은 두 번의 그래프 순회가 수행되므로 최적의 경우 (선형)시간에 수행된다. 왜냐하면 어떠한 알고리즘이라도 반드시 모든 정점과 간선을 시험해봐야 하기 때문이다. 이것은 개념적으로 가장 간단한 효율적인 알고리즘이지만 오직 한번의 순회만 시행하는 타잔의 강한 연결 요소 알고리즘이나 경로 기반 강한 요소 알고리즘에 비해 비효율적이다.

그래프가 인접 행렬로 주어질 때 ,이 알고리즘은  시간에 작동된다.

각주

[편집]
  • Alfred V. Aho, John E. Hopcroft, Jeffrey D. Ullman. Data Structures and Algorithms. Addison-Wesley, 1983.
  • Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest, Clifford Stein. Introduction to Algorithms, 3rd edition. The MIT Press, 2009. ISBN 0-262-03384-4.
  • Micha Sharir. A strong-connectivity algorithm and its applications to data flow analysis. Computers and Mathematics with Applications 7(1):67–72, 1981.